Work should be performed systematically and neatly with the final answer being underlined. This exam is open book, open notes, closed neighbor/device/browser. Allowable items on desk include: exam, pencils, and pens. All other items must be removed from student's desk. Students have Approximately 90 minutes (1 1/2 hours) to complete this exam. Best wishes!

[10 points] For the logic network shown below, find all static 1 hazards. For each 1-hazard found, specify the conditions which will cause the hazard to appear at the output (i.e. specify the logic values of the variables which are constant and clearly specify the variable that is assumed to be changing). If there are no 1-hazards found, use a K-map to show why this is the case.



Work should be performed systematically and neatly with the final answer being underlined. This exam is open Book, open notes, closed neighbor/device/browser. Allowable items on desk include: exam, pencils, and pens. All other items must be removed from student's desk. Students have approximately 90 minutes (1 1/2 hours) to complete this exam. Best wishes!

[10 points] For the logic network shown below, find all static 0 hazards. For each 0-hazard found, specify the conditions which will cause the hazard to appear at the output (i.e. specify the logic values of the variables which are constant and clearly specify the variable that is assumed to be changing). If there are no 0-hazards found, use a K-map to show why this is the case.







Work should be performed systematically and neatly with the final answer being underlined. This exam is open book, open notes, Closed neighbor/device/browser. Allowable items on desk include: exam, pencils, and pens. All other items must be removed from student's desk. Students have approximately 90 minutes (1 1/2 hours) to complete this exam. Best wishes!

[10 points] For the logic network shown below, find all static 0 hazards. For each 0-hazard found, specify the conditions which will cause the hazard to appear at the output (i.e. specify the logic values of the variables which are constant and clearly specify the variable that is assumed to be changing). If there are no 0-hazards found, use a K-map to show why this is the case.



Work should be performed systematically and neatly with the final answer being underlined. This exam is open book, open notes, closed neighbor/Device/browser. Allowable items on desk include: exam, pencils, and pens. All other items must be removed from student's desk. Students have approximately 90 minutes (1 1/2 hours) to complete this exam. Best wishes!

[10 points] For the logic network shown below, find all static 1 hazards. For each 1-hazard found, specify the conditions which will cause the hazard to appear at the output (i.e. specify the logic values of the variables which are constant and clearly specify the variable that is assumed to be changing). If there are no 1-hazards found, use a K-map to show why this is the case.



| 2. | [12 poi<br>a. | nts] Short Answer: What is the basic definition of combinational logic? What is the basic definition of sequential logic? |  |  |
|----|---------------|---------------------------------------------------------------------------------------------------------------------------|--|--|
|    |               | ismbinational logic - sufputs defendancy upon inputs, no memory / states involved                                         |  |  |
|    |               | sequential - contains memony/state, output depends on                                                                     |  |  |
|    | b.            | Does sequential logic always require a clock signal? Explain why or why not?                                              |  |  |
|    |               | no- in the case of lattres it                                                                                             |  |  |
|    |               | despends on a gate instead of a dack                                                                                      |  |  |
|    | C.            | What is the major difference between a blocking and non-blocking procedural assignment statement in Verilog?              |  |  |



e. What are the major differences between inertial and transport delays? Why are both modeled in Verilog?

modeled in Verilog?

In extial: middle gate switching, thus it suppresses
fulseg that do not equal or exceed the delay
transport! middle propagation delay, does not swallow
glitches/pulses

f. What happens to user specified timing parameters when a digital logic circuit is synthesized?

They are ignored

 [10 points] Use a single 8-to-1 MUX and a rising-edge triggered D Flip-flop to create a rising-edge triggered JK Flip-flop. Assume positive logic where a connection to VCC will be interpreted as a logic 1 and a connection to GND will be interpreted as a logic 0.



4. [8 points] Write a short Verilog description of a negative-edge triggered set/reset flip-flop that in addition to the normal active-high synchronous Set and Reset inputs also has an asynchronous Clear input that is active high (i.e. a Logic 1 clears the flip-flop output independent of the clock). Do this using Verilog Procedural Statements.

module SRFF (input Clock, Set, Reset, Clear, output reg Q);

5. [10 points] Write a Verilog Model for a Serial-in, Parallel-out 8-bit Shift Register. See the port definitions to determine required behavior.

```
// The following I/O ports are defined as follows:
// clk - global 1-bit lock signal, all operations must occur on the rising edge
// s_in - 1-bit serial data in
// shift - high to enable s_in to be clocked into the shift register, low keeps the shift
// register contents unchanged
// p_out - 8-bit parallel data out, where bit 0 is the least recent (first) serial bit to be
// shifted in and bit 7 is the most recent (last) serial bit to be shifted in
module serial_to_parallel (input clk, s_in, shift, output reg p_out[7:0])
```

always @(posedge elk)
begin
if (shift)
p-out [7:0] = \( \frac{2}{5} \)- out [7:1] \( \frac{2}{5} \)
end

6. [10 points] Based on the Serial-in, Parallel-out 8-bit Shift Register defined in problem 5, with p\_out[7:0] initially containing the value 8'h55, complete the following timing diagram by listing the p\_out signal value for every clock cycle in sequence:



P\_OUT 8155 55 AA DS DEA 75 BADD GE GE B7 DB 6D B6 5B AD 562B 2B

5. [10 points] Write a Verilog Model for a Serial-in, Parallel-out 8-bit Shift Register. See the port definitions to determine required behavior.

```
// The following I/O ports are defined as follows:
// clk - global 1-bit lock signal, all operations must occur on the rising edge
// s_in - 1-bit serial data in
// shift - high to enable s_in to be clocked into the shift register, low keeps the shift
// register contents unchanged
// p_out - 8-bit parallel data out, where bit 0 is the least recent (first) serial bit to be
shifted in and bit 7 is the most recent (last) serial bit to be shifted in
module serial_to_parallel (input clk, s_in, shift, output reg p_out[7:0])
```

6. [10 points] Based on the Serial-in, Parallel-out 8-bit Shift Register defined in problem 5, with p\_out[7:0] initially containing the value 8'hE1, complete the following timing diagram by listing the p\_out signal value for every clock cycle in sequence:



P\_OUT 8THET EI FO F8 F8 FC 7 EBF 5F AF D7 D7 EB75 BA5D 2E 17 8B8B

5. [10 points] Write a Verilog Model for a Serial-in, Parallel-out 8-bit Shift Register. See the port definitions to determine required behavior.

```
// The following I/O ports are defined as follows:
// clk - global 1-bit lock signal, all operations must occur on the rising edge
// s_in - 1-bit serial data in
// shift - high to enable s_in to be clocked into the shift register, low keeps the shift
// register contents unchanged
// p_out - 8-bit parallel data out, where bit 0 is the least recent (first) serial bit to be
// shifted in and bit 7 is the most recent (last) serial bit to be shifted in
module serial_to_parallel (input clk, s_in, shift, output reg p_out[7:0])
```

6. [10 points] Based on the Serial-in, Parallel-out 8-bit Shift Register defined in problem 5, with p\_out[7:0] initially containing the value 8'h3C, complete the following timing diagram by listing the p\_out signal value for every clock cycle in sequence:



P\_OUT 8/13C 3C 9FCFE7 F3 F9 F9 FC 7E BF BFDFEF 77 BB 5D AE57 57

 [10 points] Write a Verilog Model for a Serial-in, Parallel-out 8-bit Shift Register. See the port definitions to determine required behavior.

```
// The following I/O ports are defined as follows:
// clk - global 1-bit lock signal, all operations must occur on the rising edge
// s_in - 1-bit serial data in
// shift - high to enable s_in to be clocked into the shift register, low keeps the shift
// register contents unchanged
// p_out - 8-bit parallel data out, where bit 0 is the least recent (first) serial bit to be
// shifted in and bit 7 is the most recent (last) serial bit to be shifted in
module serial_to_parallel (input clk, s_in, shift, output reg p_out[7:0])
```

6. [10 points] Based on the Serial-in, Parallel-out 8-bit Shift Register defined in problem 5, with p\_out[7:0] initially containing the value 8'h4D, complete the following timing diagram by listing the p\_out signal value for every clock cycle in sequence:



P\_OUT 874D 4DA6 53 A 9 A 1 D 4 6 A 35 5 A 5 A 2D 96 4 B 2 5 1 2 0 90 4 02 02

7. [10 points] For the following Extended State Transition Graph shown below:



 Identify the type of synchronous sequential network it represents, and explain (Mealy FSM? Moore FSM? Combined Mealy/Moore?)



c. Write a behavioral Verilog HDL model that implements the state transition graph. In your model include a synchronous active high reset input signal that will always place the design in state SO on the active edge of the next clock pulse regardless of the current state of the network.

8. [10 points] Reduce the following state table to a minimum number of states clearly identifying the states that are equivalent with one another. Show the final reduced state table.

| Presen | t Next | Next State |        |  |
|--------|--------|------------|--------|--|
| State  | X=0    | X=1        | Output |  |
| а      | 100    | b          | 1      |  |
| b      | e 6    | eq         | 0      |  |
| C      | а      | е          | 1      |  |
| d      | d      | g          | 1      |  |
| e      | b      | а          | 0      |  |
| f      | a      | h          | 1      |  |
| g      | d      | f          | 0      |  |
| h      | g      | f          | 0      |  |

For your convenience, an iteration chart is provided below – please label grid along axes, and create additional copies if needed.



b=e :



| 9. | [5 points] True/False – Circle the correct answer |                                                                                             |  |  |
|----|---------------------------------------------------|---------------------------------------------------------------------------------------------|--|--|
|    | a.                                                | The order of continuous assignment statements determines the order in which they are        |  |  |
|    |                                                   | analyzed.                                                                                   |  |  |
|    |                                                   | TRUE or FALSE                                                                               |  |  |
|    | b.                                                | Verilog's synthesis tools treat white spaces (space or tab) and carriage returns            |  |  |
|    |                                                   | differently.                                                                                |  |  |
|    |                                                   | TRUE or FALSE                                                                               |  |  |
|    | C.                                                | There can only be one always block in a module.                                             |  |  |
|    |                                                   | TRUE or FALSE                                                                               |  |  |
|    | d.                                                | In Verilog, Behavioral Implementations generally give the designer the most control on      |  |  |
|    |                                                   | how the module will actually be implemented during the synthesis process.                   |  |  |
|    |                                                   | TRUE or FALSE                                                                               |  |  |
|    | e.                                                | A signal type must be declared as a net type (e.g. wire or tri) in Verilog in order to be a |  |  |
|    |                                                   | valid target for a procedural assignment.                                                   |  |  |
|    |                                                   | TRUE OF EALSE                                                                               |  |  |

10. [5 points] Develop a Verilog model for a 4-to-1 multiplexer where the general inputs represent a

end jusdale



What type of sequential network does this Verilog Model represent?

mealy

What type of sequential network does this Verilog Model represent?

What type of sequential network does this Verilog Model represent?

What type of sequential network does this Verilog Model represent?